Raw HTML
Text between < and > that looks like an HTML tag is parsed as a raw HTML tag and will be rendered in HTML without escaping. Tag and attribute names are not limited to current HTML tags, so custom tags (and even, say, DocBook tags) may be used.
Here is the grammar for tags:
A tag name consists of an ASCII letter followed by zero or more ASCII letters, digits, or hyphens (-).
An attribute consists of whitespace, an attribute name, and an optional attribute value specification.
An attribute name consists of an ASCII letter, _, or :, followed by zero or more ASCII letters, digits, _, ., :, or -. (Note: This is the XML specification restricted to ASCII. HTML5 is laxer.)
An attribute value specification consists of optional whitespace, a = character, optional whitespace, and an attribute value.
An attribute value consists of an unquoted attribute value, a single-quoted attribute value, or a double-quoted attribute value.
An unquoted attribute value is a nonempty string of characters not including whitespace, ", ', =, <, >, or `.
A single-quoted attribute value consists of ', zero or more characters not including ', and a final '.
A double-quoted attribute value consists of ", zero or more characters not including ", and a final ".
An open tag consists of a < character, a tag name, zero or more attributes, optional whitespace, an optional / character, and a > character.
A closing tag consists of the string </, a tag name, optional whitespace, and the character >.
An HTML comment consists of <!-- + text + -->, where text does not start with > or ->, does not end with -, and does not contain --. (See the HTML5 spec.)
A processing instruction consists of the string <?, a string of characters not including the string ?>, and the string ?>.
A declaration consists of the string <!, a name consisting of one or more uppercase ASCII letters,whitespace, a string of characters not including the character >, and the character >.
A CDATA section consists of the string <![CDATA[, a string of characters not including the string ]]>, and the string ]]>.
An HTML tag consists of an open tag, a closing tag, an HTML comment, a processing instruction, a declaration, or a CDATA section.
Here are some simple open tags:
Example 632
| Markdown | HTML | Demo |
|---|---|---|
|
|
Empty elements:
Example 633
| Markdown | HTML | Demo |
|---|---|---|
|
|
Whitespace is allowed:
Example 634
| Markdown | HTML | Demo |
|---|---|---|
|
|
With attributes:
Example 635
| Markdown | HTML | Demo |
|---|---|---|
|
|
Custom tag names can be used:
Example 636
| Markdown | HTML | Demo |
|---|---|---|
|
|
Illegal tag names, not parsed as HTML:
Example 637
| Markdown | HTML | Demo |
|---|---|---|
|
|
Illegal attribute names:
Example 638
| Markdown | HTML | Demo |
|---|---|---|
|
|
Illegal attribute values:
Example 639
| Markdown | HTML | Demo |
|---|---|---|
|
|
Illegal whitespace:
Example 640
| Markdown | HTML | Demo |
|---|---|---|
|
|
Missing whitespace:
Example 641
| Markdown | HTML | Demo |
|---|---|---|
|
|
Closing tags:
Example 642
| Markdown | HTML | Demo |
|---|---|---|
|
|
Illegal attributes in closing tag:
Example 643
| Markdown | HTML | Demo |
|---|---|---|
|
|
Comments:
Example 644
| Markdown | HTML | Demo |
|---|---|---|
|
|
Example 645
| Markdown | HTML | Demo |
|---|---|---|
|
|
Not comments:
Example 646
| Markdown | HTML | Demo |
|---|---|---|
|
|
Processing instructions:
Example 647
| Markdown | HTML | Demo |
|---|---|---|
|
|
Declarations:
Example 648
| Markdown | HTML | Demo |
|---|---|---|
|
|
CDATA sections:
Example 649
| Markdown | HTML | Demo |
|---|---|---|
|
|
Entity and numeric character references are preserved in HTML attributes:
Example 650
| Markdown | HTML | Demo |
|---|---|---|
|
|
Backslash escapes do not work in HTML attributes:
Example 651
| Markdown | HTML | Demo |
|---|---|---|
|
|
Example 652
| Markdown | HTML | Demo |
|---|---|---|
|
|